<template>
    <div class="sidebar">
        <el-menu
            class="sidebar-el-menu"
            :default-active="onRoutes"
            :collapse="collapse"
            background-color="#324157"
            text-color="#bfcbd9"
            active-text-color="#20a0ff"
            unique-opened
            router
        >
            <template v-for="item in items">
                <template v-if="item.subs">
                    <el-submenu :index="item.index" :key="item.index" v-if="item.display">
                        <template slot="title">
                            <i :class="item.icon"></i>
                            <span slot="title">{{ item.title }}</span>
                        </template>
                        <template v-for="subItem in item.subs">
                            <el-submenu
                                v-if="subItem.subs"
                                :index="subItem.index"
                                :key="subItem.index"
                            >
                                <template slot="title">{{ subItem.title }}</template>
                                <el-menu-item
                                    v-for="(threeItem,i) in subItem.subs"
                                    :key="i"
                                    :index="threeItem.index"
                                >{{ threeItem.title }}</el-menu-item>
                            </el-submenu>
                            <el-menu-item
                                v-else
                                :index="subItem.index"
                                :key="subItem.index"
                            >{{ subItem.title }}</el-menu-item>
                        </template>
                    </el-submenu>
                </template>
                <template v-else>
                    <el-menu-item :index="item.index" :key="item.index" v-if="item.display">
                        <i :class="item.icon"></i>
                        <span slot="title">{{ item.title }}</span>
                    </el-menu-item>
                </template>
            </template>
        </el-menu>
    </div>
</template>

<script>
import bus from '../common/bus';
export default {
    data() {
        return {
            collapse: false,
            status: 0,
            items: [
                {
                    icon: 'el-icon-lx-home',
                    index: '/dashboard',
                    title: '系统首页',
                    visible: [0]
                },
                {
                    icon: 'el-icon-lx-people',
                    title: '个人中心',
                    index: '1',
                    visible: [1, 2, 3],
                    subs: [
                        {
                            index: '/personal',
                            title: '个人中心'
                        },
                        {
                            index: '/personal/password',
                            title: '修改密码'
                        }
                    ]
                },
                {
                    icon: 'el-icon-lx-read',
                    index: '/manage/course',
                    title: '课程管理',
                    visible: [3]
                },
                {
                    icon: 'el-icon-lx-group',
                    index: '/manage/student',
                    title: '学生管理',
                    visible: [3]
                },
                {
                    icon: 'el-icon-lx-profile',
                    index: '/manage/teacher',
                    title: '教师管理',
                    visible: [3]
                },
                {
                    icon: 'el-icon-lx-settings',
                    index: '/manage/manager',
                    title: '管理员管理',
                    visible: [0]
                },
                {
                    icon: 'el-icon-lx-tag',
                    index: '/grade/input',
                    title: '成绩录入',
                    visible: [2]
                },
                {
				    icon: 'el-icon-lx-settings',
				    title: '系统设置',
                    index: '2',
                    visible: [3],
				    subs: [
				        {
				            index: '/settings/news',
				            title: '新闻管理'
				        },
						{
						    index: '/settings/openGrade',
						    title: '开课管理'
						}
				    ]
				},
                // {
                //     icon: 'el-icon-lx-cascades',
                //     index: '/table',
                //     title: '基础表格'
                // },
                // {
                //     icon: 'el-icon-lx-copy',
                //     index: '/tabs',
                //     title: 'tab选项卡'
                // },
                // {
                //     icon: 'el-icon-lx-calendar',
                //     index: '3',
                //     title: '表单相关',
                //     subs: [
                //         {
                //             index: '/form',
                //             title: '基本表单'
                //         },
                //         {
                //             index: '3-2',
                //             title: '三级菜单',
                //             subs: [
                //                 {
                //                     index: '/editor',
                //                     title: '富文本编辑器'
                //                 },
                //                 {
                //                     index: '/markdown',
                //                     title: 'markdown编辑器'
                //                 }
                //             ]
                //         },
                //         {
                //             index: '/upload',
                //             title: '文件上传'
                //         }
                //     ]
                // },
				{
				    icon: 'el-icon-lx-emoji',
				    index: '/course/choose',
                    title: '选课',
                    visible: [1]
                },
                {
				    icon: 'el-icon-lx-skin',
				    index: '/student/comment',
                    title: '课程评价',
                    visible: [1]
                },
                {
                    icon: 'el-icon-lx-people',
                    title: '课表查询',
                    index: '/student/studentCourse',
                    visible: [1]
                },
                {
				    icon: 'el-icon-menu',
				    index: '/teacher/course',
                    title: '查看课程',
                    visible: [2]
                },
                {
                    icon: 'el-icon-lx-emoji',
                    index: '/icon',
                    title: '自定义图标',
                    visible: [0]
                },
                // {
                //     icon: 'el-icon-pie-chart',
                //     index: '/charts',
                //     title: 'schart图表'
                // },
                // {
                //     icon: 'el-icon-rank',
                //     index: '6',
                //     title: '拖拽组件',
                //     subs: [
                //         {
                //             index: '/drag',
                //             title: '拖拽列表'
                //         },
                //         {
                //             index: '/dialog',
                //             title: '拖拽弹框'
                //         }
                //     ]
                // },
                // {
                //     icon: 'el-icon-lx-global',
                //     index: '/i18n',
                //     title: '国际化功能'
                // },
                // {
                //     icon: 'el-icon-lx-warn',
                //     index: '7',
                //     title: '错误处理',
                //     subs: [
                //         {
                //             index: '/permission',
                //             title: '权限测试'
                //         },
                //         {
                //             index: '/404',
                //             title: '404页面'
                //         }
                //     ]
                // },
                {
                    icon: 'el-icon-lx-redpacket_fill',
                    index: '/donate',
                    title: '测试',
                    visible: [0]
                }
            ]
        };
    },
    computed: {
        onRoutes() {
            return this.$route.path.replace('/', '');
        }
    },
    created() {
        // 通过 Event Bus 进行组件间通信，来折叠侧边栏
        bus.$on('collapse', msg => {
            this.collapse = msg;
            bus.$emit('collapse-content', msg);
        });
        this.status = this.$store.state.status;
        this.visibles();
    },
    methods: {
        visibles() {
            for (let i = 0;i < this.items.length;i++) {
                let item = this.items[i];
                item['display'] = (item.visible.indexOf(Number(this.status)) !== -1);
            }
        }
    }
};
</script>

<style scoped>
.sidebar {
    display: block;
    position: absolute;
    left: 0;
    top: 70px;
    bottom: 0;
    overflow-y: scroll;
}
.sidebar::-webkit-scrollbar {
    width: 0;
}
.sidebar-el-menu:not(.el-menu--collapse) {
    width: 250px;
}
.sidebar > ul {
    height: 100%;
}
</style>
